我们有一个多元化的开发团队,一个在Windows上,另一个在Ubuntu上,另一个在OSX上。作为windows男孩,我设置了vagrant安装脚本的第一个版本,它运行得非常好;)但是,当它在Ubuntu主机上运行时,第一次进入调用bash脚本的配置步骤时,由于权限问题而失败。在Windows上,这无关紧要,因为samba共享自动具有足够的权限来运行bash脚本(它位于项目层次结构中,因此存在于VM上的/vagrant共享中),但是对于ubuntu,我需要在我调用它之前在配置脚本中设置对此文件的权限。这不是问题,老实说,我怀疑即使有额外的“chmod”步骤,它在Windows下仍然可以
我知道您可以通过键入查看所有可能的佣金任务rake-T但我需要知道任务的具体作用。从输出中,如何找到实际具有任务的源文件?例如,我正在尝试查找db:schema:dump任务的源。 最佳答案 我知道这是一个老问题,但无论如何:rake-W这是在rake0.9.0中引入的。http://rake.rubyforge.org/doc/release_notes/rake-0_9_0_rdoc.htmlSupportforthe–where(-W)flagforshowingwhereataskisdefined.
我有这个小佣金任务:namespace:dbdonamespace:testdotask:resetdoENV['RAILS_ENV']="test"Rake::Task['db:drop'].invokeRake::Task['db:create'].invokeRake::Task['db:migrate'].invokeendendend现在,当我执行时,它将忽略我尝试硬编码的RAILS_ENV。我如何使这个任务按预期工作 最佳答案 对于这个特定的任务,您只需要更改数据库连接,正如Adam指出的那样,您可以这样做:namesp
假设我有一个这样的rakefile:file'file1'=>some_dependenciesdosh'externaltoolIdonothavecontrolover,whichsometimesfailtocreatethefile'???endtask:default=>'file1'doputs"everything'sOK"end现在,如果我不放置任何内容来代替???,即使外部工具无法生成文件,我也会收到OK消息。什么是通知rake的正确方法,'file1'任务失败了,它应该中止(希望呈现一个有意义的消息——比如哪个任务失败了)——我现在唯一能想到的就是在那里引发异常,但
我将收割机线放入rake任务中,以杀死一些额外生成的ruby任务,因为它们有时会不知何故爬上来。system"psaux|grep'namespace:taskname'|grepruby|grep-vgrep|awk'{print$2}'|xargskill-9;echo'Reapedoldnamespace:tasknameprocesses.'"我想在其中添加grep-v$PID_OF_CURRENT_TASK以确保我不会终止当前正在运行的任务。我如何获得该PID? 最佳答案 您可以使用Process.pid在Ruby中获
我已经使用WindowsRuby安装程序安装了Ruby2.0,将DevKit(DevKit-mingw64-64-4.7.2-20130224-1432-sfx.exe)解压到ProgramFiles并运行rubydk.rbinit但是生成的config.yml文件没有列出我的Ruby路径。其内容如下所示:#Thisconfigurationfilecontainstheabsolutepathlocationsofall#installedRubiestobeenhancedtoworkwiththeDevKit.Thisconfig#fileisgeneratedbythe'rub
我有一个Rake任务将配置数据从文件加载到数据库中,是否有正确的ruby/rails方法在迁移时调用它?我的目标是同步我的团队数据库配置,无需广播然后运行任务lalaladefself.upchange_table:fis_situacao_fiscaldo|t|t.remove:mostrar_enderecot.rename:serie,:modeloendFaturamento::Cfop.destroy_all()#performrakehere!end更新我现在的工作方式和工作方式:system('rakesistema:load_datafile=faturamento
我正在构建一个集成测试套件,我需要一个干净的数据库来处理一些逻辑。如何在我的一个测试中运行db:test:purge任务?我正在使用:ruby1.9.2、rails3.0.9、rspec2.6 最佳答案 您可以按如下方式调用Rake任务:require'rake'Rake::Task[name].invoke在这种情况下,这将导致以下代码:require'rake'Rake::Task['db:test:purge'].invoke 关于ruby-在Rspec测试中运行Rake任务,我们
我有一个Rakefile,其中包含我通常从命令行调用的Rake任务:rakeblog:postTitle我想编写一个多次调用Rake任务的Ruby脚本,但我看到的唯一解决方案是使用``(反引号)或system进行处理。正确的做法是什么? 最佳答案 来自timocracy.com:require'rake'defcapture_stdouts=StringIO.newoldstdout=$stdout$stdout=syields.stringensure$stdout=oldstdoutendRake.application.rak
我希望这个问题得到一般性的回答,但为了说明这一点,这里有一个用例:我将Vagrant用于一个简单的LMAP项目。我使用独立的Puppet进行配置。现在,可能有一些开发人员坐在代理后面,他们需要对VM进行一些额外的配置。我在Puppet方面有一些工作:我可以将代理IP(如果有的话)作为事实传递给Vagrantfile中的puppet,如果已设置,Puppet会做出相应的react。我唯一的问题是:开发人员如何为他们的开发环境指定/覆盖此设置,而不必更改Vagrantfile(它在版本控制下并且必须保持开发环境中立)?如果人们可以覆盖文件中的一些Vagrant设置,那就太棒了。Vagran